为了账号安全,请及时绑定邮箱和手机立即绑定

jquery map调用get()方法的困惑

标签:
JQuery

         

$( "p" )  .append( $( "input" ).map(function() {    return $( this ).val();  })  .get()  .join( ", " ) );
<form>  <input type="text" name="name" value="John">  <input type="text" name="password" value="password">  <input type="text" name="url" value="http://ejohn.org/"></form>

这是我从官网拿出来的一个example

本人曾经很困惑,不明白为什么在map方法的后面要在调用一个get方法。按照理论来说,map 返回出来的数据应该一个数组(集合)。 可以直接调用join方法转化为string.


仔细阅读文档后发现这里有文章。


我原来混淆的javascript object/array(其实就是dom) 和jqeruy object/ array这两个概念

其实javascript的对象和数组和jquery的是相互不能识别的。 

当我发现了这个”秘密“之后,就大概明白为什么需要get 方法了


.get(): Retrieve the DOM elements matched by the jQuery object.

这是官网的定义。就是把jquery 对象转为dom 对象。 所有的dom对象都是可以被javascript所使用的。这里jquery其实就是通过get这个机制来顺利过渡两者。


所以我们回头看上面这个例子 

map 返回了jquery array 然后通过get方法转为javascript dom array。 最后调用join方法变为string.


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
移动开发工程师
手记
粉丝
18
获赞与收藏
134

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消